## **ARM2 Instructions**

| Name and description                | Addressing modes                                                                                     | Status<br>N Z C V I F | <ul> <li>Some instructions can optionally update the<br/>status flags, e.g. ADDS R0, R1, R2</li> <li>Use ! to update Rn when pre-indexing, e.g. LDR R0, [R1, #4]!</li> </ul> |                                                                                                                  |                       |
|-------------------------------------|------------------------------------------------------------------------------------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|-----------------------|
| ADC<br>Arithmetic add<br>with carry | ADC Rd, Rn, #imm ADC Rd, Rn, Rm ADC Rd, Rn, Rm shift #cnt ADC Rd, Rn, Rm shift Rs ADC Rd, Rn, Rm RRX | * * * *<br>(if S)     | Status Abbreviations  * may change                                                                                                                                           |                                                                                                                  | r ROR                 |
| <b>ADD</b><br>Arithmetic add        | ADD Rd, Rn, #imm ADD Rd, Rn, Rm                                                                      | * * * *<br>(if S)     | AL CC CS EQ addr 26 bit address GE GT HI LE reg_list e.g. R2, R4-R6 LS LT MI NE off offset in range of -40954095 NV PL VC VS                                                 |                                                                                                                  |                       |
|                                     | ADD Rd, Rn, Rm shift #cnt<br>ADD Rd, Rn, Rm shift Rs<br>ADD Rd, Rn, Rm RRX                           | (11-3)                | Name and description                                                                                                                                                         | Addressing modes                                                                                                 | Status<br>N Z C V I F |
| AND<br>Logical AND                  | AND Rd, Rn, #imm AND Rd, Rn, Rm AND Rd, Rn, Rm shift #cnt AND Rd, Rn, Rm shift Rs AND Rd, Rn, Rm RRX | * * *<br>(if S)       | MVN<br>Move complement of<br>register                                                                                                                                        | MVN Rd, #imm<br>MVN Rd, Rm<br>MVN Rd, Rm shift #cnt<br>MVN Rd, Rm shift Rs<br>MVN Rd, Rm RRX                     | * * *<br>(if S)       |
| <b>B</b><br>Branch                  | B addr                                                                                               |                       | ORR<br>Logical OR                                                                                                                                                            | ORR Rd, Rn, #imm<br>ORR Rd, Rn, Rm<br>ORR Rd, Rn, Rm shift #cnt                                                  | * * *<br>(if S)       |
| <b>BIC</b><br>Bit clear             | BIC Rd, Rn, #imm BIC Rd, Rn, Rm                                                                      | * * *<br>(if S)       | RSB                                                                                                                                                                          | ORR Rd, Rn, Rm shift Rs<br>ORR Rd, Rn, Rm RRX                                                                    |                       |
| BL                                  | BIC Rd, Rn, Rm shift #cnt<br>BIC Rd, Rn, Rm shift Rs<br>BIC Rd, Rn, Rm RRX                           |                       | Reverse-operand subtract                                                                                                                                                     | RSB Rd, Rn, #imm<br>RSB Rd, Rn, Rm<br>RSB Rd, Rn, Rm shift #cnt<br>RSB Rd, Rn, Rm shift Rs                       | * * * *<br>(if S)     |
| Branch with link<br>(R14 ← PC)      | BL addr                                                                                              |                       | RSC                                                                                                                                                                          | RSB Rd, Rn, Rm RRX                                                                                               |                       |
| CMN<br>Set negative<br>compare      | CMN Rn, #imm CMN Rn, Rm CMN Rn, Rm shift #cnt CMN Rn, Rm shift Rs CMN Rn, Rm RRX                     | * * * *               | Reverse-operand<br>subtract with<br>carry                                                                                                                                    | RSC Rd, Rn, #imm RSC Rd, Rn, Rm RSC Rd, Rn, Rm shift #cnt RSC Rd, Rn, Rm shift Rs RSC Rd, Rn, Rm RRX             | * * * *<br>(if S)     |
| CMP<br>Arithmetic<br>comparison     | CMP Rn, #imm CMP Rn, Rm CMP Rn, Rm shift #cnt CMP Rn, Rm shift Rs                                    | * * * *               | SBC<br>Subtract with<br>carry                                                                                                                                                | SBC Rd, Rn, #imm<br>SBC Rd, Rn, Rm<br>SBC Rd, Rn, Rm shift #cnt<br>SBC Rd, Rn, Rm shift Rs<br>SBC Rd, Rn, Rm RRX | * * * *<br>(if S)     |
| <b>EOR</b> Logical exclusive OR     | CMP Rn, Rm RRX  EOR Rd, Rn, #imm EOR Rd, Rn, Rm                                                      | * * *<br>(if S)       | STM<br>Store multiple<br>registers                                                                                                                                           | <pre>STMmode Rn, { reg_list }</pre>                                                                              |                       |
| LDM                                 | EOR Rd, Rn, Rm shift #cnt<br>EOR Rd, Rn, Rm shift Rs<br>EOR Rd, Rn, Rm RRX                           | (11 3)                | STR Store register to memory                                                                                                                                                 | STR Rd, [Rn, #off] STR Rd, [Rn, Rm] STR Rd, [Rn, Rm shift #cnt] STR Rd, [Rd], #off STR Rd, [Rd], Rm              |                       |
| Load multiple registers             | LDMmode Rn, { reg_list }                                                                             |                       | SUB                                                                                                                                                                          | STR Rd, [Rd], Rm shift #cnt                                                                                      |                       |
| LDR<br>Load register from<br>memory | LDR Rd, [Rn, #off] LDR Rd, [Rn, Rm] LDR Rd, [Rn, Rm shift #cnt] LDR Rd, [Rd], #off LDR Rd, [Rd], Rm  |                       | Subtract                                                                                                                                                                     | SUB Rd, Rn, #imm SUB Rd, Rn, Rm SUB Rd, Rn, Rm shift #cnt SUB Rd, Rn, Rm shift Rs SUB Rd, Rn, Rm RRX             | * * * *<br>(if S)     |
| <b>MLA</b><br>Multiply and          | LDR Rd, [Rd], Rm shift #cnt  MLA Rd, Rm, Rs, Rn                                                      | * * X                 | SWI<br>Software interrupt                                                                                                                                                    | SWI operand                                                                                                      |                       |
| accumulate<br><b>MOV</b>            |                                                                                                      | (if S)                | <b>TEQ</b> Set condition codes via XOR                                                                                                                                       | TEQ Rn, #imm TEQ Rn, Rm                                                                                          | * * *                 |
| Move register or<br>constant        | MOV Rd, #imm MOV Rd, Rm MOV Rd, Rm shift #cnt MOV Rd, Rm shift Rs MOV Rd, Rm spift Rs                | * * *<br>(if S)       | TST                                                                                                                                                                          | TEQ Rn, Rm shift #cnt<br>TEQ Rn, Rm shift Rs<br>TEQ Rn, Rm RRX                                                   |                       |
| MUL<br>Multiply                     | MOV Rd, Rm RRX  MUL Rd, Rm, Rs                                                                       | * * X                 | Set condition codes via AND                                                                                                                                                  | TST Rn, #imm<br>TST Rn, Rm<br>TST Rn, Rm shift #cnt                                                              | * * *                 |

Inspired by 6502 Instructions by Beagle Bros

Any instruction can be conditional, e.g. MOVEQ R0, R1